



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

Applicant(s): Fu-Hwa Wang  
Assignee: Sun Microsystems, Inc.  
Title: Compiler Annotation for Binary Translation Tools  
Serial No.: 10/002,238 Filing Date: November 2, 2001  
Examiner: Satish Rampuria Group Art Unit: 2124  
Docket No.: P6165 Customer No.: 33438

Austin, Texas  
September 21, 2005

MAIL STOP AF  
COMMISSIONER FOR PATENTS  
P.O. Box 1450  
Alexandria, VA 22313-1450

**PRE-APPEAL BRIEF REQUEST FOR REVIEW  
AND STATEMENT OF REASONS**

Sir:

Applicant requests review of the Final Rejection in the above-identified application. No amendments are being filed with the request. This request is being filed with a Notice of Appeal. The following sets forth a succinct, concise, and focused set of arguments for which the review is being requested.

**CLAIM STATUS**

Claims 1, 2, 3, 5, 8, 9, 10, 12, 16, 17, 18, 20-23, 25 - 28 and 30 - 40 stand rejected under Chen, U.S. Patent No. 6,625,807 (Chen) in view of Zucker, U.S. Patent No. 5,991,871 (Zucker).

**REMARKS**

The following remarks provide applicants' position regarding how the claims distinguish over the art of record. While not discussed herein, all the arguments presented regarding hindsight reconstruction and suggestion to combine are maintained.

The present invention generally relates to an optimizing compiler that adds annotation information (i.e., compiler annotation) to an executable binary code file. The compiler annotation provides information useful for binary translators such that a binary translator does not have to use a heuristic approach to translate binary code. Compiler annotation identifies such information as function boundaries, split functions, jump table information, function addresses and code labels. (See e.g., application page 3, liens 1 – 9.)

Chen discloses a method for register optimization during code translation and utilizes a technique that removes the time overhead for analyzing register usage and eliminates fixed restraints on the compiler register usage. The method for register optimization utilizes a compiler to produce a bit vector for each program unit (i.e., subroutine, function, and/or procedure). Each bit in the bit vector represents a particular caller-saved register. A bit is set if the compiler uses the corresponding register within that program unit. During the translation, the translator examines the bit vector to very quickly determine which registers are free, and therefore can be used during register optimization without having to save and restore the register values.

Zucker discloses interfacing a binary application program to a computer system. The application binary interface includes linkage structures for interfacing the binary application program to a digital computer. A function in a relocatable shared object module obtains the absolute address of a Global Offset Table (GOT) in the module using relative branch and link instructions through the computer's link register. A dynamic linker constructs a Procedure Linkage Table (PLT) and a pointer table for an object module in a process memory image in which space is allocated for the PLT, but the PLT is not initially provided. The pointer table stores absolute addresses of external functions that cannot be reached by relative branching from the module. The PLT receives calls to these functions, gets the absolute addresses from the pointer table and branches to the absolute addresses of the functions. The PLT also receives calls to functions that can be reached by relative branching from the module, and causes relative branching to the functions.

Zucker sets forth that a binary application object file program is configured in an Executable and Linking Format (ELF). More specifically, Zucker sets forth:

The object program 60 comprises an ELF header 64 that specifies the number and sizes of the sections of the program 60, in addition to other information required by the

operating system 48. A section header table 66 is also provided, including information required to locate all of the sections of the file 60.

The actual text (program instructions) and data of the program are provided in a number of discrete sections, designated as  $68_1$  to  $68_N$ . A dynamic section 70 contains dynamic linking information for use by the dynamic linker 54 (Zucker Col. 8, lines 28 -39).

In general, neither Chen nor Zucker does not disclose or suggest method of producing a binary code file where the binary code file includes binary code instruction and *compiler annotation* where the *compiler annotation is an ELF section*, as substantially required by each of the independent claims. The ELF header 64 of Zucker neither teaches nor suggests the claimed binary code file having both binary code instructions and compiler annotation which is an ELF section.

More specifically, Chen and Zucker, taken alone or in combination, do not teach or a method of producing a binary code file which includes compiling a plurality of source code instructions, and outputting a plurality of binary code instructions and compiler annotation wherein *the plurality of binary code instructions is executable by a processor of a computer system and are an executable and linking format (ELF) binary code file and the compiler annotation is an ELF section*, all as required by claim 1. Accordingly, claim 1 is allowable over Chen and Zucker. Claims 2 - 7 depend from claim 1 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest a method of translating a source binary code file which includes translating a plurality of source binary code instructions utilizing compiler annotation and the outputting a plurality of target binary code instructions wherein the plurality of source binary code instructions are *an executable and linking format (ELF) binary code file* and the compiler is *an ELF section* and the plurality of target binary code instructions is executable by a processor of a computer system, all as required by claim 8. Accordingly, claim 8 is allowable over Chen and Zucker. Claims 9 - 15 depend from claim 8 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest a binary code file which includes a plurality of binary code instructions and compiler annotation where the plurality of binary code instructions are *an executable and linking format (ELF) binary code file* and the compiler annotation is *an ELF section*, all as required by claim 16. Accordingly, claim 16 is allowable over Chen and Zucker. Claims 17 - 20 depend from claim 16 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for producing a binary code file which includes means for outputting a plurality of binary code instructions and compiler annotation wherein the plurality of source binary code instructions are *an executable and linking format (ELF) binary code file* and the compiler annotation is *an ELF section*, all as required by claim 21. Accordingly, claim 21 is allowable over Chen and Zucker. Claims 22 - 25 depend from claim 21 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for translating a source binary code file which includes means for translating a plurality of source binary code instructions utilizing compiler annotation, and means for outputting a plurality of target binary code instructions wherein *the plurality of source binary code instructions are an executable and linking format (ELF) binary code file and the compiler annotation is an ELF section* all as required by claim 26. Accordingly, claim 26 is allowable over Chen and Zucker. Claims 27 - 30 depend from claim 26 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for producing a binary code file which includes instructions stored on a computer readable medium to compile a plurality of source code instructions, and output a plurality of binary code instructions and compiler annotation wherein *the plurality of source binary code instructions are an executable and linking format (ELF) binary code file and the compiler annotation is an ELF section*, all as required by claim 31. Accordingly, claim 31 is allowable over Chen and Zucker. Claims 32 - 35 depend from claim 31 and are allowable for at least this reason.

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for translating a source binary code file which includes instructions stored on a computer readable medium to translate a plurality of source binary code instructions utilizing compiler annotation, and output a plurality of target binary code instructions wherein *the plurality of source binary code instructions are an executable and linking format (ELF) binary code file and the compiler annotation is an ELF section*, all as required by claim 36. Accordingly, claim 36 is allowable over Chen and Zucker. Claims 37 - 40 depend from claim 36 and are allowable for at least this reason.

In view of the arguments set forth herein, the application is believed to be in condition for allowance and a notice to that effect is solicited. Nonetheless, should any issues remain that might be subject to resolution through a telephonic interview, please telephone the undersigned.

|                                                                                                                                                                                                                                                            |                   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| I hereby certify that this correspondence is being deposited with the United States Postal Service as First Class Mail in an envelope addressed to: Mail Stop AF, COMMISSIONER FOR PATENTS, PO Box 1450, Alexandria, VA 22313-1450, on September 21, 2005. |                   |
|                                                                                                                                                                           | 9/21/05           |
| Attorney for Applicant(s)                                                                                                                                                                                                                                  | Date of Signature |

Respectfully submitted,  
  
Stephen A. Terrile  
Attorney for Applicant(s)  
Reg. No. 32,946